﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;

namespace ZX.TR.Library
{
    /// <summary>
    /// 
    /// </summary>
    [Serializable]
    [Table(Name = "TrIndagate")]
    [ZX.DBModule.Table("TrIndagate", "TrIndagateID")]
    public class V_IndagateList : ZX.DBModule.BaseEntity
    {

        #region Business Methods 业务方法

        /// <summary>
        /// ID
        /// </summary>
        private static PropertyInfo<Guid> TrIndagateIDProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<Guid>("TrIndagateID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid TrIndagateID
        {
            get { return GetProperty(TrIndagateIDProperty); }
            set { SetProperty(TrIndagateIDProperty, value); }
        }
        /// <summary>
        /// 问卷ID
        /// </summary>
        private static PropertyInfo<Guid> TrQuestionnaireIDProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<Guid>("TrQuestionnaireID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid TrQuestionnaireID
        {
            get { return GetProperty(TrQuestionnaireIDProperty); }
            set { SetProperty(TrQuestionnaireIDProperty, value); }
        }
        /// <summary>
        /// 活动ID
        /// </summary>
        private static PropertyInfo<Guid> TrActivityIDProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<Guid>("TrActivityID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid TrActivityID
        {
            get { return GetProperty(TrActivityIDProperty); }
            set { SetProperty(TrActivityIDProperty, value); }
        }
        /// <summary>
        /// 调研类型（前、后）
        /// </summary>
        private static PropertyInfo<string> IndagateTypeProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<string>("IndagateType"));
        [Column]
        public string IndagateType
        {
            get { return GetProperty(IndagateTypeProperty); }
            set { SetProperty(IndagateTypeProperty, value); }
        }
        /// <summary>
        /// 调研主题
        /// </summary>
        private static PropertyInfo<string> IndagateTopicProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<string>("IndagateTopic"));
        [Column]
        public string IndagateTopic
        {
            get { return GetProperty(IndagateTopicProperty); }
            set { SetProperty(IndagateTopicProperty, value); }
        }
        /// <summary>
        /// 调研内容
        /// </summary>
        private static PropertyInfo<string> IndagateContentProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<string>("IndagateContent"));
        [Column]
        public string IndagateContent
        {
            get { return GetProperty(IndagateContentProperty); }
            set { SetProperty(IndagateContentProperty, value); }
        }
        /// <summary>
        /// 活动名称
        /// </summary>
        private static PropertyInfo<string> ActivityNameProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<string>("ActivityName"));
        [Column]
        public string ActivityName
        {
            get { return GetProperty(ActivityNameProperty); }
            set { SetProperty(ActivityNameProperty, value); }
        }
        /// <summary>
        /// 问卷名称
        /// </summary>
        private static PropertyInfo<string> QuestionnaireNameProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<string>("QuestionnaireName"));
        [Column]
        public string QuestionnaireName
        {
            get { return GetProperty(QuestionnaireNameProperty); }
            set { SetProperty(QuestionnaireNameProperty, value); }
        }
        /// <summary>
        /// 问卷目的
        /// </summary>
        private static PropertyInfo<string> QAimProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<string>("QAim"));
        [Column]
        public string QAim
        {
            get { return GetProperty(QAimProperty); }
            set { SetProperty(QAimProperty, value); }
        }
        /// <summary>
        /// 得数
        /// </summary>
        private static PropertyInfo<decimal> GetPointProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<decimal>("GetPoint"));
        [Column]
        public decimal GetPoint
        {
            get { return GetProperty(GetPointProperty); }
            set { SetProperty(GetPointProperty, value); }
        }
        /// <summary>
        /// 调研总结
        /// </summary>
        private static PropertyInfo<string> IndagateSumaryProperty = RegisterProperty(typeof(V_IndagateList), new PropertyInfo<string>("IndagateSumary"));
        [Column]
        public string IndagateSumary
        {
            get { return GetProperty(IndagateSumaryProperty); }
            set { SetProperty(IndagateSumaryProperty, value); }
        }

        #endregion

        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            ValidationRules.AddRule(CommonRules.StringRequired, "IndagateType");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("IndagateType", 1));
            ValidationRules.AddRule(CommonRules.StringRequired, "IndagateTopic");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("IndagateTopic", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "IndagateContent");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("IndagateContent", 500));
            //base.AddBusinessRules();
        }
        #endregion

        #region Factory Methods 工厂方法

        public V_IndagateList() { }

        public static V_IndagateList New()
        {
            return DataPortal.Create<V_IndagateList>();
        }
        public static V_IndagateList Get(Guid TrIndagateID)
        {
            return DataPortal.Fetch<V_IndagateList>(new SingleLazyCriteria<V_IndagateList, Guid>(TrIndagateID, false));
        }
        public static void Delete(Guid TrIndagateID)
        {
            DataPortal.Delete(TrIndagateID);
        }

        //public override TrIndagate Save()
        //{
        //return base.Save();
        //}
        #endregion

        #region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid TrIndagateID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
            using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("TrIndagateID").Equal(TrIndagateID);
                var data = db.Select<V_IndagateList>(q)[0];
                LoadProperty(TrIndagateIDProperty, data.TrIndagateID);
                LoadProperty(TrQuestionnaireIDProperty, data.TrQuestionnaireID);
                LoadProperty(TrActivityIDProperty, data.TrActivityID);
                LoadProperty(IndagateTypeProperty, data.IndagateType);
                LoadProperty(IndagateTopicProperty, data.IndagateTopic);
                LoadProperty(IndagateContentProperty, data.IndagateContent);
                LoadProperty(ActivityNameProperty, data.ActivityName);
                LoadProperty(QuestionnaireNameProperty, data.QuestionnaireName);
                LoadProperty(QAimProperty, data.QAim);
                LoadProperty(GetPointProperty, data.GetPoint);
                LoadProperty(IndagateSumaryProperty, data.IndagateSumary);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(TrIndagateIDProperty);
        }
        #endregion

    }
}
